Создание нескольких IServiceProvider.
Singleton.
  • Из одного набора IServiceCollection может быть создано несколько объектов IServiceProvider. Но у каждого из них будет свое управление и scope.
    Например если создать 2 экземпляра IServiceProvider, и от каждого из них запросить по одному ISingletonService, то мы получим 2 разных экземпляра ISingletonService.
  • Это может вызвать проблемы так, как обычно IServiceProvider формируется внутри фреймворка.
    Если самостоятельно создать экземпляр IServiceProvider, то получаем отдельное пространство и кривые объекты ISingletonService.
    (Например, если некоторые зависимости необходимы в самом процессе регистрации основного контейнера, конфигурации IServiceCollection)
    Также проблема может усугубиться, если самостоятельно созданный IServiceProvider в некоторых местах выступит в роли Factory/ServiceLocator.
  • Остро эта проблема проявляется для таких ISingletonService, у которых есть свое изменяемое состояние.
Валидация при сборке Di контейнера.services.BuildServiceProvider(
   new ServiceProviderOptions()
    {
        ValidateOnBuild = true,
        ValidateScopes = true
    }
    );
Регистрация одного типа (экземпляра) для нескольких абстракций.services.AddScoped<TImplementation>();

services.AddScoped<TInterface1>(s => s.GetRequiredService<TImplementation>());
services.AddScoped<TInterface2>(s => s.GetRequiredService<TImplementation>());

В случае, если регистрировать через указание интерфейса и типа реализации, то будет создано несколько экземпляров TImplementation, а не один.

 

Теги: